﻿<!DOCTYPE HTML>
<html lang="zh">
<head>
<title>格式化时间 - 语法 &amp; 使用 | AutoHotkey v2</title>
<meta name="description" content="The 格式化时间 function transforms a YYYYMMDDHH24MISS timestamp into the specified date/time 格式化字符串." />
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<link href="../static/theme.css" rel="stylesheet" type="text/css" />
<script src="../static/content.js" type="text/javascript"></script>
<script type="text/javascript">$(function(){0<=window.navigator.userAgent.toLowerCase().indexOf("ucbrowser")&&CaoNiMaDeUc()})</script>
<style type="text/css">
.red {color: #FF0000}
</style>
</head>
<body>

<h1>格式化时间</h1>

<p>将 <a href="FileSetTime.htm#YYYYMMDD">YYYYMMDDHH24MISS</a> 时间戳转换为指定的日期/时间格式.</p>

<pre class="Syntax">字符串 := <span class="func">格式化时间</span>(<span class="optional"><a href="FileSetTime.htm#YYYYMMDD">YYYYMMDDHH24MISS</a>, 格式化字符串</span>)</pre>
<h2 id="Parameters">参数</h2>
<dl>

  <dt>YYYYMMDD...</dt>
  <dd>
    <p>类型: <a href="../Concepts.htm#strings">字符串</a></p>
    <p>留空此参数以使用当前本地日期和时间. 否则, 请指定 <a href="FileSetTime.htm#YYYYMMDD">YYYYMMDDHH24MISS</a> 格式时间戳的全部或前面的部分.</p>
  </dd>

  <dt>格式化字符串</dt>
  <dd>
    <p>类型: <a href="../Concepts.htm#strings">字符串</a></p>
    <p>如果省略, 则它默认为时间后跟着长日期, 并且会对它们根据当前用户区域设置进行格式化. 例如: 4:55 PM Saturday, November 27, 2004</p>
    <p>否则, 请指定一个或多个下面的日期-时间格式以及在它们之间的任何原义空格和标点(逗号不需要转义; 它们可以正常使用). 在下面的例子中, 请注意 M 必须为大写: M/d/yyyy h:mm tt</p>
  </dd>

</dl>

<h2 id="Return_Value">返回值</h2>
<p>类型: <a href="../Concepts.htm#strings">字符串</a></p>
<p>该函数返回指定时间戳的转换版本.</p>
<p>如果 <em>YYYYMMDDHH24MISS</em> 包含无效的日期和/或时间部分 -- 例如非闰年的 2 月 29 日 -- 那么日期和/或时间将从返回值中省略. 虽然只支持 1601 年到 9999 年之间的年份, 但只要时间部分有效, 仍然可以为更早的年份生成格式化的时间.</p>
<p>如果 <em>格式化字符串</em> 包含超过 2000 个字符, 则返回一个空字符串.</p>

<h2 id="Date_Formats_case_sensitive">日期格式(区分大小写)</h2>
<table class="info">
  <tr>
    <td style="width:15%">d</td>
    <td>不含前导零的天数(1 &ndash; 31)</td>
  </tr>
  <tr>
    <td>dd</td>
    <td>含前导零的天数(01 &ndash; 31)</td>
  </tr>
  <tr>
    <td>ddd</td>
    <td>在当前的用户语言里星期几的简称(例如, 周一)</td>
  </tr>
  <tr>
    <td>dddd</td>
    <td>在当前的用户语言里星期几的全称(例如, 星期一)</td>
  </tr>
  <tr>
    <td>M</td>
    <td>不含前导零的月份(1 &ndash; 12)</td>
  </tr>
  <tr>
    <td>MM</td>
    <td>含前导零的月份(01 &ndash; 12)</td>
  </tr>
  <tr>
    <td>MMM</td>
    <td>在当前的用户语言里月份的简称(例如, 一月)</td>
  </tr>
  <tr>
    <td>MMMM</td>
    <td>在当前的用户语言里月份的全称(例如, 一月)</td>
  </tr>
  <tr>
    <td>y</td>
    <td>不含世纪的年份, 不含前导零(0 &ndash; 99)</td>
  </tr>
  <tr>
    <td>yy</td>
    <td>不含世纪的年份, 含前导零(00 &ndash; 99)</td>
  </tr>
  <tr>
    <td>yyyy</td>
    <td>含世纪的年份. 例如: 2005</td>
  </tr>
  <tr>
    <td>gg</td>
    <td>当前用户区域设置的时代/纪元字符串(如果没有则为空)</td>
  </tr>
</table>
<h2>时间格式(区分大小写)</h2>
<table class="info">
  <tr>
    <td style="width:15%">h</td>
    <td>不含前导零的小时数; 十二小时制格式(1 &ndash; 12)</td>
  </tr>
  <tr>
    <td>hh</td>
    <td>含前导零的小时数; 十二小时制格式(01 &ndash; 12)</td>
  </tr>
  <tr>
    <td>H</td>
    <td>不含前导零的小时数; 二十四小时制格式(0 &ndash; 23)</td>
  </tr>
  <tr>
    <td>HH</td>
    <td>含前导零的小时数; 二十四小时制格式(00 &ndash; 23)</td>
  </tr>
  <tr>
    <td>m</td>
    <td>不含前导零的分钟数(0 &ndash; 59)</td>
  </tr>
  <tr>
    <td>mm</td>
    <td>含前导零的分钟数(00 &ndash; 59)</td>
  </tr>
  <tr>
    <td>s</td>
    <td>不含前导零的秒数(0 &ndash; 59)</td>
  </tr>
  <tr>
    <td>ss</td>
    <td>含前导零的秒数(00 &ndash; 59)</td>
  </tr>
  <tr>
    <td>t</td>
    <td>单字符时间标记, 例如 A 或 P(取决于区域设置)</td>
  </tr>
  <tr>
    <td>tt</td>
    <td>多字符时间标记, 例如 AM 或 PM(取决于区域设置)</td>
  </tr>
</table>
<h2>独立格式</h2>
  <p>下面的格式必须 <strong>单独</strong> 使用; 即在 <em>格式化字符串</em> 参数中不能含有其他格式或文本. 这些格式不区分大小写.</p>
<table class="info">
  <tr>
    <td style="width:15%">(空)</td>
    <td>留空 <em>格式化字符串</em> 来生成时间后跟着长日期. 例如, 在某些区域设置中它可能看起来像这样 4:55 PM Saturday, November 27, 2004(译者注: 显示的内容与顺序与系统设置有关, 中文: 下午 4:55 星期六,2004年11月27日)</td>
  </tr>
  <tr>
    <td>Time</td>
    <td>当前用户区域设置的时间表示, 例如 5:26 PM(译者注: 显示的内容与顺序与系统设置有关, 中文: 下午 5:26)</td>
  </tr>
  <tr>
    <td>ShortDate</td>
    <td>当前用户区域设置的短日期表示, 例如 02/29/04(译者注: 显示的内容与顺序与系统设置有关, 中文: 2004/2/29 )</td>
  </tr>
  <tr>
    <td>LongDate</td>
    <td>当前用户区域设置的长日期表示, 例如 Friday, April 23, 2004(译者注: 显示的内容与顺序与系统设置有关, 中文: 星期五,2004年4月23日)</td>
  </tr>
  <tr>
    <td>YearMonth</td>
    <td>当前用户区域设置的年份和月份格式, 例如 February, 2004(译者注: 显示的内容与顺序与系统设置有关, 中文: 2004年2月)</td>
  </tr>
  <tr>
    <td>YDay</td>
    <td>不含前导零的年份的天数(1 &ndash; 366)</td>
  </tr>
  <tr>
    <td>YDay0</td>
    <td>含前导零的年份的天数(001 &ndash; 366)</td>
  </tr>
  <tr>
    <td>WDay</td>
    <td>星期的天数(1 &ndash; 7). 星期天为 1.</td>
  </tr>
  <tr>
    <td>YWeek</td>
    <td>ISO 8601 中规定的完全年份和周数. 例如: 200453. 如果含有 1 月 1 日的星期有四天以上在新年里, 则它被认为是新年的第一星期. 否则, 它为前一年的最后一个星期, 而下一星期为新年的第一星期. 因此, 1 月 4 日和首个星期四总是在第一周.</td>
  </tr>
</table>
<h2>附加选项</h2>
<p>下列选项可以紧跟在 <em>YYYYMMDDHH24MISS</em> 时间戳后(如果没有时间戳, 它们也可以单独使用). 在下面的例子中, 请注意最后的四项间没有逗号:</p>
<pre>OutputVar := 格式化时间("20040228 LSys D1 D4")</pre>
<p><strong>R</strong>: 反转. 让日期在时间之前(仅当 <em>格式化字符串</em> 为空时才有意义).</p>
<p><strong>自然对数</strong>: 如果此选项 <em>不</em> 存在, 则使用当前用户区域设置来格式化字符串. 要使用系统的区域设置, 请指定 LSys. 要使用特殊的区域设置, 请指定字母 L 后面跟着十六进制或十进制的区域设置标识符(LCID). 关于如何构建 LCID 的信息, 请在  <a href="https://www.microsoft.com">www.microsoft.com</a> 上搜索下列短语: Locale Identifiers</p>
<p><strong>Dn</strong>: 日期选项. 请指定 <strong>n</strong> 为下列数字的其中一个:<br>
  0: 强制使用默认选项. 这也会让短日期生效. <br>
  1: 使用短日期(仅当 <em>格式化字符串</em> 为空时才有意义; 与 2 和 8 不兼容).<br>
  2: 使用长日期(仅当 <em>格式化字符串</em> 为空时才有意义; 与 1 和 8 不兼容).<br>
  4: 使用备用日历(如果有).<br>
  8: 使用年份-月份格式(仅当 <em>格式化字符串</em> 为空时才有意义; 与 1 和 2 不兼容).<br>
  0x10: 为从左到右的阅读顺序布局添加标记.<br>
  0x20: 为从右到左的阅读顺序布局添加标记.<br>
  0x80000000: 不遵循任何用户对系统默认日期格式的覆盖.<br>
  0x40000000: 使用系统 ANSI 代码页而不是区域设置代码页进行字符串转换.</p>
<p><strong>Tn</strong>: 时间选项. 请指定 <strong>n</strong> 为下列数字的其中一个:<br>
  0: 强制使用默认选项. 这也使得会显示分钟数和秒数.<br>
  1: 省略分钟数和秒数.<br>
  2: 省略秒数. <br>
  4: 省略时间标记(例如 AM/PM).<br>
  8: 始终使用二十四小时制而不是十二小时制.<br>
  12: 上面两个参数的组合.<br>
  0x80000000: 不遵循任何用户对系统默认时间格式的覆盖. <br>
  0x40000000: 使用系统 ANSI 代码页而不是区域设置代码页进行字符串转换.</p>
<p class="note"><strong>注意</strong>: Dn 和 Tn 可以使用多次以使多个选项生效, 例如: <code>格式化时间("20040228 D2 D4 T1 T8")</code></p>
<h2 id="Remarks">备注</h2>
<p>您希望从 <em>格式化字符串</em>原义转换到最终字符串中的字母和数字应该用单引号括起来, 如此例所示: <code>"'Date:' MM/dd/yy 'Time:' hh:mm:ss tt"</code>.</p>
<p>相反, 非字母数字字符(例如空格, tab, 换行符(`n), 斜杠, 冒号, 逗号和其他标点) 不需要包围在单引号中. 例外情况是单引号字符本身: 要产生原义的单引号, 请使用四个连续的单引号(''''), 不过如果它们已经包含在一对外部引号中则仅使用连续的两个就行了.</p>
<p>如果 <em>格式化字符串</em> 同时包含日期和时间元素, 则它们不能混用. 换句话说, 这个字符串应该分成两半: 一半时间, 一半日期. 例如, 包含 &quot;hh yyyy mm&quot; 的格式字符串不会产生期望的结果, 因为它在两个时间元素间包含日期元素.</p>
<p>当 <em>格式化字符串</em> 包含数值的天数(d 或 dd) 后跟着月份的全称(MMMM), 则使用月份名称的所有格形式(如果当前语言有所有格形式).</p>
<p>相关提示, 可以使用 <a href="DateAdd.htm">时间偏移</a> 和 <a href="DateDiff.htm">取时间差</a> 对日期和时间进行加减和比较.</p>
<h2 id="Related">相关</h2>
<p>要进行反向的转换 -- 即, <em>从</em> 格式化的日期/时间 <em>转换到</em> <a href="FileSetTime.htm#YYYYMMDD">YYYYMMDDHH24MISS</a> 格式 -- 请参阅 <a href="https://www.autohotkey.com/forum/topic20405.html">www.autohotkey.com/forum/topic20405.html</a></p>
<p>另请参阅: <a href="GuiControls.htm#DateTime">界面 DateTime 控件</a>, <a href="../Variables.htm#date">内置的日期和时间变量</a>, <a href="FileGetTime.htm">获取文件时间</a></p>
<h2 id="Examples">示例</h2>
<div class="ex" id="ExBasic">
<p><a href="#ExBasic">#1</a></p>
<pre>TimeString := 格式化时间()
信息框 "The current time and date (time first) is " TimeString

TimeString := 格式化时间("R")
信息框 "The current time and date (date first) is " TimeString

TimeString := 格式化时间(, "Time")
信息框 "The current time is " TimeString

TimeString := 格式化时间("T12", "Time")
信息框 "The current 24-hour time is " TimeString

TimeString := 格式化时间(, "LongDate")
信息框 "The current date (long 格式化字符串) is " TimeString

TimeString := 格式化时间(20050423220133, "dddd MMMM d, yyyy hh:mm:ss tt")
信息框 "The specified date and time, when formatted, is " TimeString

信息框 格式化时间(200504, "'Month Name': MMMM`n'Day Name': dddd")

YearWeek := 格式化时间(20050101, "YWeek")
信息框 "January 1st of 2005 is in the following ISO year and week number: " YearWeek</pre>
</div>

<div class="ex" id="ExFileTime">
<p><a href="#ExFileTime">#2</a>: 改变文件的日期-时间戳:</p>
<pre>FileName := 文件选择框(3,, "Pick a file")
如果 FileName = "" <em>; 用户没有选取文件.</em>
    返回
FileTime := 获取文件时间(FileName)
FileTime := 格式化时间(FileTime)   <em>; 由于省略了最后一个参数, 所以获取长日期和时间.</em>
信息框 "The selected file was last modified at " FileTime</pre>
</div>

<div class="ex" id="ExFormatSec">
<p><a href="#ExFormatSec">#3</a>: 下面的函数把指定的秒数转换成相应的小时数, 分钟数和秒数(hh:mm:ss 格式).</p>
<pre>信息框 FormatSeconds(7384)  <em>; 7384 = 2 小时 + 3 分钟 + 4 秒. 它的结果: 2:03:04</em>

FormatSeconds(NumberOfSeconds)  <em>; 把指定的秒数转换成 hh:mm:ss 格式.</em>
{
    time := 19990101  <em>; 任意日期的 *午夜*.</em>
    time := 时间偏移(time, NumberOfSeconds, "Seconds")
    返回 NumberOfSeconds//3600 &quot;:&quot; 格式化时间(time, "mm:ss")
    <em>/*
    ; 和上面方法不同的是, 这里不支持超过 24 小时的秒数:
    返回 格式化时间(time, "h:mm:ss")
    */</em>
}</pre>
</div>

</body>
</html>